package com.Sep_Thirtyy;

/**
 * 921. 使括号有效的最少添加
 * 只有满足下面几点之一，括号字符串才是有效的：
 *
 * 它是一个空字符串，或者
 * 它可以被写成 AB （A 与 B 连接）, 其中 A 和 B 都是有效字符串，或者
 * 它可以被写作 (A)，其中 A 是有效字符串。
 * 给定一个括号字符串 s ，移动N次，你就可以在字符串的任何位置插入一个括号。
 *
 * 例如，如果 s = "()))" ，你可以插入一个开始括号为 "(()))" 或结束括号为 "())))" 。
 * 返回 为使结果字符串 s 有效而必须添加的最少括号数。
 *
 *  
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode.cn/problems/minimum-add-to-make-parentheses-valid
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 *
 * 2022/09/30 13:45
 */

public class Solution921 {

    public int minAddToMakeValid(String s) {
        int ans=0,now=0;
        for (int i=0;i<s.length();i++)
        {
            if (s.charAt(i)=='(')
            {
                now++;
            }else
            {
                now--;
            }
            if (now<0)
            {
                now++;
                ans++;
            }
        }
        return ans+now;
    }

    public static void main(String[] args) {
        Solution921 solution921=new Solution921();
        System.out.println(solution921.minAddToMakeValid("((("));
    }

}
